<template>
    <DrawerPro
        v-model="drawerVisible"
        :header="$t('commons.button.bind')"
        :resource="licenseName"
        @close="handleClose"
        size="small"
    >
        <el-form ref="formRef" label-position="top" :model="form" @submit.prevent v-loading="loading">
            <el-form-item :label="$t('setting.bindNode')" prop="nodeID" :rules="Rules.requiredSelect">
                <el-select filterable v-model="form.nodeID" class="w-full" clearable>
                    <el-option v-for="item in freeNodes" :key="item.id" :label="item.name" :value="item.id" />
                </el-select>
            </el-form-item>
            <el-card class="mt-5" v-if="form.nodeID && form.nodeID !== 0">
                <div class="mb-2">
                    <span>{{ $t('xpack.node.syncInfo') }}</span>
                </div>
                <el-form-item prop="syncListItem">
                    <el-checkbox-group v-model="form.syncListItem">
                        <div class="ml-5">
                            <el-checkbox :label="$t('xpack.node.syncProxy')" value="SyncSystemProxy" />
                        </div>
                        <div class="ml-5">
                            <el-checkbox :label="$t('xpack.node.syncAlertSetting')" value="SyncAlertSetting" />
                        </div>
                        <div class="ml-5">
                            <el-checkbox :label="$t('xpack.node.syncCustomApp')" value="SyncCustomApp" />
                        </div>
                        <div class="ml-5">
                            <el-checkbox :label="$t('xpack.node.syncBackupAccount')" value="SyncBackupAccounts" />
                        </div>
                    </el-checkbox-group>
                    <span class="input-help">{{ $t('xpack.node.syncHelper') }}</span>
                </el-form-item>
            </el-card>
        </el-form>
        <template #footer>
            <el-button @click="drawerVisible = false">{{ $t('commons.button.cancel') }}</el-button>
            <el-button :disabled="loading" type="primary" @click="onBind(formRef)">
                {{ $t('commons.button.confirm') }}
            </el-button>
        </template>
    </DrawerPro>

    <DockerProxyDialog ref="dockerProxyRef" @submit="submit" v-model:with-docker-restart="withDockerRestart" />
</template>
<script lang="ts" setup>
import { reactive, ref } from 'vue';
import i18n from '@/lang';
import { MsgSuccess } from '@/utils/message';
import { bindLicense, listNodeOptions } from '@/api/modules/setting';
import DockerProxyDialog from '@/components/docker-proxy/dialog.vue';
import { FormInstance } from 'element-plus';
import { GlobalStore } from '@/store';
import { Rules } from '@/global/form-rules';
const globalStore = GlobalStore();

interface DialogProps {
    licenseName: string;
    licenseID: number;
}
const drawerVisible = ref();
const loading = ref();
const licenseName = ref();
const freeNodes = ref([]);

const dockerProxyRef = ref();
const withDockerRestart = ref(false);

const form = reactive({
    nodeID: null,
    licenseID: null,
    syncList: '',
    syncListItem: ['SyncSystemProxy', 'SyncAlertSetting', 'SyncCustomApp', 'SyncBackupAccounts'],
});

const formRef = ref<FormInstance>();

const acceptParams = (params: DialogProps): void => {
    licenseName.value = params.licenseName;
    form.licenseID = params.licenseID;
    loadNodes();
    drawerVisible.value = true;
};

const onBind = async (formEl: FormInstance | undefined) => {
    if (!formEl) return;
    formEl.validate(async (valid) => {
        if (!valid) return;
        form.syncList = form.syncListItem?.join(',') || '';
        dockerProxyRef.value.acceptParams({ syncList: form.syncList });
    });
};

const submit = async () => {
    loading.value = true;
    await bindLicense({
        licenseID: form.licenseID,
        nodeID: form.nodeID,
        syncList: form.syncList,
        withDockerRestart: withDockerRestart.value,
    })
        .then(() => {
            loading.value = false;
            MsgSuccess(i18n.global.t('commons.msg.operationSuccess'));
            window.location.reload();
        })
        .catch(() => {
            loading.value = false;
        });
};

const loadNodes = async () => {
    if (!globalStore.isMasterProductPro) {
        freeNodes.value = [{ id: 0, name: globalStore.getMasterAlias() }];
        return;
    }
    await listNodeOptions('free')
        .then((res) => {
            freeNodes.value = res.data || [];
        })
        .catch(() => {
            freeNodes.value = [];
        });
};

const handleClose = () => {
    drawerVisible.value = false;
};

defineExpose({
    acceptParams,
});
</script>
